<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>

  <!-- 
    
    总结
    1. class是ES6的语法糖，class实际上是构造函数
    2. 函数也是对象
    3. static是ES6的关键字，等同于给class加上一个属性；
    4. static 也可以放在方法钱，等于与给class加了一个方法
    5. 静态的方法和属性，就是我们说的静态成员
  
  -->

  <script>
    class Person {

      // 用=声明的属性或方法，会在实例对象身上
      name = 'zs';
      // static相当于给构造函数对象，加上了一个age属性
      // 等同于 Person.age = 18
      static age = 18;


      // 用函数声明的方法，会在原型对象身上
      static sayHi() {
        console.log('哈哈')
      }
      goodBye() {
        console.log('拜拜')
      }
    }



    // class 其实是构造函数的语法糖, 可以用来创建对象
    const obj = new Person()
    console.log(Person.age, 'Person.age')
    console.log(Person.sayHi, 'Person.sayHi')
    console.log(obj, 'obj')

  </script>

</body>

</html>